// mainjs 应用入口 项目的初始化 全局通用的事情

import Vue from 'vue'
// 引入一个初始化样式文件 margin padding
import 'normalize.css/normalize.css'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'

import '@/styles/index.scss' // global css

// 引入根组件
import App from './App'

// 引入vuex
import store from './store'

// 引入路由router
import router from './router'

// 引入字体图标
import '@/icons' // icon

// 导入permissionjs 直接导入会执行（模块中如果有同步代码，会立即执行）
import '@/permission'

// 全局组件的注册(pagetools)
// import PageTools from '@/components/PageTools'
// Vue.component(PageTools.name, PageTools)

// 注册按钮权限的自定义指令
import '@/directive'

// 注册插件(pagetools)
import componentPlugin from '@/components'
// 全局使用插件
Vue.use(componentPlugin)

// 把 elementui注册为全局可用
Vue.use(ElementUI)

Vue.config.productionTip = false

// 访问VUE_APP_PORT
// console.log(process.env.VUE_APP_PORT)

// vue实例化
new Vue({
  el: '#app',
  // router, store 挂载  深度绑定
  router,
  store,
  // 类比为 template模板 把app根组件进行渲染挂载 app组件一旦渲染 底层子组件会跟着渲染
  render: h => h(App)
})
